home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
MacGames Sampler
/
PHT MacGames Bundle.iso
/
MacSource Folder
/
Samples from the CD
/
C and C++
/
Gnuplot 3.5 for Macintosh
/
SOURCES 3.5
/
term
/
epson.trm
< prev
next >
Wrap
Text File
|
1993-11-03
|
16KB
|
632 lines
/*
* $Id: epson.trm%v 3.50 1993/07/09 05:35:24 woo Exp $
*
*/
/* GNUPLOT - epson.trm */
/*
* Copyright (C) 1990 - 1993
*
* Permission to use, copy, and distribute this software and its
* documentation for any purpose with or without fee is hereby granted,
* provided that the above copyright notice appear in all copies and
* that both that copyright notice and this permission notice appear
* in supporting documentation.
*
* Permission to modify the software is granted, but not the right to
* distribute the modified code. Modifications are to be distributed
* as patches to released version.
*
* This software is provided "as is" without express or implied warranty.
*
* This file is included by ../term.c.
*
* This terminal driver supports:
* epson_lx800, nec_cp6, starc,
* epson_60dpi, tandy_60dpi
* epson_180dpi
*
* AUTHORS
* Russell Lang
* William Wilson
*
* send your comments or suggestions to (info-gnuplot@dartmouth.edu).
*
*/
/* The following epson lx800 driver uses generic bit mapped graphics
routines to build up a bit map in memory. */
/* by Russell Lang, rjl@monu1.cc.monash.edu.au */
/* On PC, print using 'copy file /b lpt1:', do NOT use 'print' */
/* EPSON_init changes outfile to binary mode on PC's */
#ifdef EPSONP
#define EPSONXMAX 512
#define EPSONYMAX 384
#define EPSONXLAST (EPSONXMAX - 1)
#define EPSONYLAST (EPSONYMAX - 1)
#define EPSONVCHAR FNT5X9_VCHAR
#define EPSONHCHAR FNT5X9_HCHAR
#define EPSONVTIC 6
#define EPSONHTIC 6
EPSONinit()
{
#ifdef REOPEN_BINARY
reopen_binary();
#endif
}
EPSONgraphics()
{
b_charsize(FNT5X9);
b_makebitmap((unsigned int)(EPSONXMAX*xsize),
(unsigned int)(EPSONYMAX*ysize),1);
}
EPSONtext()
{
epson_dump();
b_freebitmap();
}
#define EPSONlinetype b_setlinetype
#define EPSONmove b_move
#define EPSONvector b_vector
#define EPSONput_text b_put_text
#define EPSON_text_angle b_text_angle
EPSONreset()
{
#ifdef vms
fflush_binary();
#endif
}
/* output file must be binary mode for epson_dump */
epson_dump()
{
register unsigned int x;
int j;
for (j=(b_ysize/8)-1; j>=0; j--) {
/* select plotter graphics mode (square pixels) */
fprintf(outfile,"\033J\030"); /* line feed 8/72" = 8 dots */
fprintf(outfile,"\r\033*\005");
(void) fputc((char)(b_xsize%256),outfile);
(void) fputc((char)(b_xsize/256),outfile);
for (x=0; x<b_xsize; x++) {
(void) fputc( (char)(*((*b_p)[j]+x)), outfile );
}
}
#ifdef PC
fprintf(stderr,"Print using: COPY /B\n");
#endif
}
#endif /* EPSONP */
/* The following NEC CP6 Pinwriter driver uses generic bit mapped graphics
routines to build up a bit map in memory. */
/* by Russell Lang, rjl@monu1.cc.monash.edu.au */
/* On PC, print using 'copy file /b lpt1:', do NOT use 'print' */
/* NECinit changes outfile to binary mode for PC's */
/* Add a Monochrome NEC printer (for faster speed and line types) jdc */
#ifdef NEC
#define NECXMAX 400
#define NECYMAX 320
#define NECXLAST (NECXMAX - 1)
#define NECYLAST (NECYMAX - 1)
#define NECVCHAR FNT5X9_VCHAR
#define NECHCHAR FNT5X9_HCHAR
#define NECVTIC 6
#define NECHTIC 6
/* plane 0=black, 1=cyan(blue), 2=magenta(red), 3=yellow */
static unsigned int neccolor[] = {1,8,4,2,10,12,6,14};
static unsigned int necpcolor[]= {0,2,1,4};
static int NECmode;
NECoptions()
{
if( END_OF_COMMAND ) {
strcpy(term_options,"monochrome");
NECmode='m';
} else
if( almost_equals(c_token,"m$onochrome") ) {
c_token++;
strcpy(term_options,"monochrome");
NECmode='m';
} else
if( almost_equals(c_token,"c$olor") ) {
c_token++;
strcpy(term_options,"color");
NECmode='c';
} else
if( almost_equals(c_token,"d$raft") ) {
c_token++;
strcpy(term_options,"draft");
NECmode='d';
} else {
/* error, but since the terminal is already set, default to mono */
strcpy(term_options,"monochrome");
NECmode='m';
int_error("modes: color, monochrome, draft",c_token);
}
}
NECinit()
{
#ifdef REOPEN_BINARY
reopen_binary();
#endif
}
NECgraphics()
{
b_charsize(FNT5X9);
b_makebitmap((unsigned int)(NECXMAX*xsize),
(unsigned int)(NECYMAX*ysize),(NECmode=='c' ? 4 : 1));
}
NECtext()
{
if( NECmode=='d' ) {
nec_draft_dump();
} else {
nec_dump();
}
b_freebitmap();
}
NEClinetype(linetype)
int linetype;
{
if( NECmode=='c' ) {
if (linetype>=6)
linetype %= 6;
b_setvalue(neccolor[linetype+2]);
} else {
b_setlinetype(linetype);
}
}
#define NECmove b_move
#define NECvector b_vector
#define NECput_text b_put_text
#define NEC_text_angle b_text_angle
NECreset()
{
#ifdef vms
fflush_binary();
#endif
}
/* output file must be binary mode for nec_dump */
nec_dump()
{
unsigned int x;
unsigned int plane,offset;
int j;
unsigned int column8;
unsigned long column24;
char column3, column2, column1;
fprintf(outfile,"\033P\033l\005"); /* 10cpi, left margin 5 char */
for (j=(b_ysize/8)-1;j>=0;j--) {
fprintf(outfile,"\033J\030"); /* 24/180" line feed */
for (plane=0; plane<b_planes; plane++) {
offset=plane*b_psize;
if (b_planes>1) {
/* select colour for plane */
fprintf(outfile,"\033r");
(void) fputc((char)necpcolor[plane],outfile);
}
/* select plotter graphics mode (square pixels) */
fprintf(outfile,"\r\033*\047");
(void) fputc((char)((b_xsize*3)%256),outfile);
(void) fputc((char)((b_xsize*3)/256),outfile);
for (x=0; x<b_xsize; x++) {
column8= (unsigned int)(*((*b_p)[j+offset]+x));
column24=0;
if (column8&0x01) column24|=(long)0x000007;
if (column8&0x02) column24|=(long)0x000038;
if (column8&0x04) column24|=(long)0x0001c0;
if (column8&0x08) column24|=(long)0x000e00;
if (column8&0x10) column24|=(long)0x007000;
if (column8&0x20) column24|=(long)0x038000;
if (column8&0x40) column24|=(long)0x1c0000;
if (column8&0x80) column24|=(long)0xe00000;
column1 = (char) ( column24 & (long)0xff);
column2 = (char) ((column24>>8) & (long)0xff);
column3 = (char) ((column24>>16) & (long)0xff);
(void) fputc(column3,outfile);
(void) fputc(column2,outfile);
(void) fputc(column1,outfile);
(void) fputc(column3,outfile);
(void) fputc(column2,outfile);
(void) fputc(column1,outfile);
(void) fputc(column3,outfile);
(void) fputc(column2,outfile);
(void) fputc(column1,outfile);
}
}
}
fprintf(outfile,"\r\033l");
(void) fputc('\0',outfile); /* set left margin to 0 */
if (b_planes > 1) {
fprintf(outfile,"\033r");
(void) fputc('\0',outfile); /* set color to black */
}
#ifdef PC
fprintf(stderr,"Print using: COPY /B\n");
#endif
#ifdef vms
fflush_binary();
#endif
}
/* output file must be binary mode for nec_dump */
nec_draft_dump()
{
unsigned int x;
unsigned int plane,offset;
int j;
fprintf(outfile,"\033P\033l\005\r"); /* 10cpi, left margin 5 char */
for (j=(b_ysize/8)-1;j>=0;j--) {
fprintf(outfile,"\033J\030"); /* 24/180" line feed */
for (plane=0; plane<b_planes; plane++) {
offset=plane*b_psize;
if (b_planes>1) {
/* select colour for plane */
fprintf(outfile,"\033r");
(void) fputc((char)necpcolor[plane],outfile);
}
/* select plotter graphics mode (square pixels) */
fprintf(outfile,"\r\033*");
(void) fputc('\0',outfile);
(void) fputc((char)(b_xsize%256),outfile);
(void) fputc((char)(b_xsize/256),outfile);
for (x=0; x<b_xsize; x++) {
(void) fputc( (char)(*((*b_p)[j+offset]+x)), outfile );
}
}
}
fprintf(outfile,"\r\033l");
(void) fputc('\0',outfile); /* set left margin to 0 */
if (b_planes > 1) {
fprintf(outfile,"\033r");
(void) fputc('\0',outfile); /* set color to black */
}
#ifdef PC
fprintf(stderr,"Print using: COPY /B\n");
#endif
}
#endif /* NEC */
#ifdef STARC
/* The following Star color driver uses generic bit mapped graphics
routines to build up a bit map in memory. */
/* Star Color changes made by William Wilson, wew@naucse.cse.nau.edu */
/* On PC, print using 'copy file /b lpt1:', do NOT use 'print' */
/* STARC_init changes outfile to binary mode on PC's */
#define STARCXMAX 512
#define STARCYMAX 384
#define STARCXLAST (STARCXMAX - 1)
#define STARCYLAST (STARCYMAX - 1)
#define STARCVCHAR FNT5X9_VCHAR
#define STARCHCHAR FNT5X9_HCHAR
#define STARCVTIC 6
#define STARCHTIC 6
/* plane 0=black, 1=cyan(blue), 2=magenta(red), 3=yellow */
static unsigned int STARCcolor[] = {1,8,4,2,10,12,6,14};
static unsigned int STARCpcolor[]= {0,2,1,4};
STARCinit()
{
#ifdef REOPEN_BINARY
reopen_binary();
#endif
}
STARCgraphics()
{
b_charsize(FNT5X9);
b_makebitmap((unsigned int)(STARCXMAX*xsize),
(unsigned int)(STARCYMAX*ysize),4);
}
STARCtext()
{
STARC_dump();
b_freebitmap();
}
STARClinetype(linetype)
int linetype;
{
if (linetype>=6)
linetype %= 6;
b_setvalue(STARCcolor[linetype+2]);
}
#define STARCmove b_move
#define STARCvector b_vector
#define STARCput_text b_put_text
#define STARC_text_angle b_text_angle
STARCreset()
{
#ifdef vms
fflush_binary();
#endif
}
/* output file must be binary mode for STARC_dump */
STARC_dump()
{
unsigned int x;
unsigned int plane,offset;
int j;
for (j=(b_ysize/8)-1;j>=0;j--) {
fprintf(outfile,"\033J\030"); /* line feed 8/72" = 8 dots */
for (plane=0; plane<b_planes; plane++) {
offset=plane*b_psize;
if (b_planes>1) {
/* select colour for plane */
fprintf(outfile,"\033r");
(void) fputc((char)STARCpcolor[plane],outfile);
}
/* select plotter graphics mode (square pixels) */
fprintf(outfile,"\r\033*\005");
(void) fputc((char)(b_xsize%256),outfile);
(void) fputc((char)(b_xsize/256),outfile);
for (x=0; x<b_xsize; x++) {
(void) fputc( (char)(*((*b_p)[j+offset]+x)), outfile );
}
}
}
if (b_planes > 1) {
fprintf(outfile,"\033r");
(void) fputc('\0',outfile); /* set color to black */
}
#ifdef PC
fprintf(stderr,"Print using: COPY /B\n");
#endif
}
#endif /* STARC */
#ifdef EPS180
#define EPSON180VCHAR FNT13X25_VCHAR
#define EPSON180HCHAR FNT13X25_HCHAR
#define EPSON180VTIC 18
#define EPSON180HTIC 18
/* make the total dimensions 8 inches by 6 inches */
#define EPS180XMAX 1260
#define EPS180YMAX 1080
#define EPS180XLAST (EPS180XMAX - 1)
#define EPS180YLAST (EPS180YMAX - 1)
EPS180graphics()
{
b_charsize(FNT13X25);
b_makebitmap((unsigned int)(EPS180XMAX*xsize),
(unsigned int)(EPS180YMAX*ysize),1);
}
EPS180text()
{
eps180_dump();
b_freebitmap();
}
/* output file must be binary mode for eps180_dump */
eps180_dump()
{
register unsigned int x;
int j;
fprintf(outfile,"\033@\033+\060\033l\005"); /* reset, set line spacing
to 24/180", and
move left margin */
for (j=(b_ysize/8)-1; j>=0; ) {
/* select printer graphics mode '39' */
fprintf(outfile,"\r\n\033*'");
(void) fputc((char)(b_xsize%256),outfile);
(void) fputc((char)(b_xsize/256),outfile);
for (x=0; x<b_xsize; x++) {
(void) fputc( (char)(*((*b_p)[j]+x)), outfile );
(void) fputc( (char)(*((*b_p)[j-1]+x)), outfile );
(void) fputc( (char)(*((*b_p)[j-2]+x)), outfile );
}
j -= 3;
}
fprintf(outfile,"\r\n\033@\r\n"); /* reset printer */
#ifdef PC
fprintf(stderr,"Print using: COPY /B\n");
#endif
}
#endif /* EPS180 */
#ifdef EPS60
/* make the total dimensions 8 inches by 5 inches */
#define EPS60XMAX 480
#define EPS60YMAX 360
#define EPS60XLAST (EPS60XMAX - 1)
#define EPS60YLAST (EPS60YMAX - 1)
EPS60graphics()
{
b_charsize(FNT5X9);
b_makebitmap((unsigned int)(EPS60XMAX*xsize),
(unsigned int)(EPS60YMAX*ysize),1);
}
EPS60text()
{
eps60_dump();
b_freebitmap();
}
/* output file must be binary mode for eps60_dump */
eps60_dump()
{
register unsigned int x;
int j;
fprintf(outfile,"\033%c\030",'3'); /* set line spacing 24/216" = 8 dots */
for (j=(b_ysize/8)-1; j>=0; j--) {
/* select printer graphics mode 'K' */
fprintf(outfile,"\r\n\033K");
(void) fputc((char)(b_xsize%256),outfile);
(void) fputc((char)(b_xsize/256),outfile);
for (x=0; x<b_xsize; x++) {
(void) fputc( (char)(*((*b_p)[j]+x)), outfile );
}
}
fprintf(outfile,"\033%c\044\r\n",'3'); /* set line spacing 36/216" = 1/6" */
#ifdef PC
fprintf(stderr,"Print using: COPY /B\n");
#endif
}
#endif /* EPS60 */
#ifdef TANDY60
/* The only difference between TANDY60 and EPS60 is the inclusion
of codes to swap the Tandy printer into IBM mode and back
into Tandy mode. For a Tandy already in IBM mode, use EPS60. */
TANDY60text()
{
#ifdef PC
fprintf(stderr, "Inserting Tandy/IBM mode conversion codes\n");
#endif
/* Switch to IBM mode, and leave 3 inches above the plot so as
to get rough vertical centring on the page. Perform the
centring by setting 1" line feeds and issuing 3 of them. */
fprintf(outfile, "\033!\033%c%c\n\n\n", '3',216);
eps60_dump();
b_freebitmap();
/* A form feed must be sent before switching back to Tandy mode,
or else the form setting will be messed up. */
fprintf(outfile, "\f\033!");
}
#endif /* TANDY60 */
#ifdef OKIDATA
OKIDATAtext()
{
okidata_dump();
b_freebitmap();
}
int bitrev_tbl[] = {
0x00, 0x80, 0x40, 0xc0, 0x20, 0xa0, 0x60, 0xe0,
0x10, 0x90, 0x50, 0xd0, 0x30, 0xb0, 0x70, 0xf0,
0x08, 0x88, 0x48, 0xc8, 0x28, 0xa8, 0x68, 0xe8,
0x18, 0x98, 0x58, 0xd8, 0x38, 0xb8, 0x78, 0xf8,
0x04, 0x84, 0x44, 0xc4, 0x24, 0xa4, 0x64, 0xe4,
0x14, 0x94, 0x54, 0xd4, 0x34, 0xb4, 0x74, 0xf4,
0x0c, 0x8c, 0x4c, 0xcc, 0x2c, 0xac, 0x6c, 0xec,
0x1c, 0x9c, 0x5c, 0xdc, 0x3c, 0xbc, 0x7c, 0xfc,
0x02, 0x82, 0x42, 0xc2, 0x22, 0xa2, 0x62, 0xe2,
0x12, 0x92, 0x52, 0xd2, 0x32, 0xb2, 0x72, 0xf2,
0x0a, 0x8a, 0x4a, 0xca, 0x2a, 0xaa, 0x6a, 0xea,
0x1a, 0x9a, 0x5a, 0xda, 0x3a, 0xba, 0x7a, 0xfa,
0x06, 0x86, 0x46, 0xc6, 0x26, 0xa6, 0x66, 0xe6,
0x16, 0x96, 0x56, 0xd6, 0x36, 0xb6, 0x76, 0xf6,
0x0e, 0x8e, 0x4e, 0xce, 0x2e, 0xae, 0x6e, 0xee,
0x1e, 0x9e, 0x5e, 0xde, 0x3e, 0xbe, 0x7e, 0xfe,
0x01, 0x81, 0x41, 0xc1, 0x21, 0xa1, 0x61, 0xe1,
0x11, 0x91, 0x51, 0xd1, 0x31, 0xb1, 0x71, 0xf1,
0x09, 0x89, 0x49, 0xc9, 0x29, 0xa9, 0x69, 0xe9,
0x19, 0x99, 0x59, 0xd9, 0x39, 0xb9, 0x79, 0xf9,
0x05, 0x85, 0x45, 0xc5, 0x25, 0xa5, 0x65, 0xe5,
0x15, 0x95, 0x55, 0xd5, 0x35, 0xb5, 0x75, 0xf5,
0x0d, 0x8d, 0x4d, 0xcd, 0x2d, 0xad, 0x6d, 0xed,
0x1d, 0x9d, 0x5d, 0xdd, 0x3d, 0xbd, 0x7d, 0xfd,
0x03, 0x83, 0x43, 0xc3, 0x23, 0xa3, 0x63, 0xe3,
0x13, 0x93, 0x53, 0xd3, 0x33, 0xb3, 0x73, 0xf3,
0x0b, 0x8b, 0x4b, 0xcb, 0x2b, 0xab, 0x6b, 0xeb,
0x1b, 0x9b, 0x5b, 0xdb, 0x3b, 0xbb, 0x7b, 0xfb,
0x07, 0x87, 0x47, 0xc7, 0x27, 0xa7, 0x67, 0xe7,
0x17, 0x97, 0x57, 0xd7, 0x37, 0xb7, 0x77, 0xf7,
0x0f, 0x8f, 0x4f, 0xcf, 0x2f, 0xaf, 0x6f, 0xef,
0x1f, 0x9f, 0x5f, 0xdf, 0x3f, 0xbf, 0x7f, 0xff
};
/* output file must be binary mode for okidata_dump */
okidata_dump()
{
register unsigned int x;
int j;
char cur_char;
int prev_char;
prev_char = 0;
fprintf(outfile,"\033%c%c\020\033*eP:\003",'%','9'); /* set line spacing 16/144" = 8 dots :Turned on single density graphics mode*/
for (j=(b_ysize/8)-1; j>=0; j--) {
fprintf(outfile,"\003\016");
/* (void) fputc((char)(b_xsize%256),outfile); */
/* (void) fputc((char)(b_xsize/256),outfile); */
for (x=0; x<b_xsize; x++) {
if ( (cur_char = (char)
(bitrev_tbl[ (int) (*((*b_p)[j]+x))])) == '\003') {
fprintf( outfile, "\003\003");
}
else {
(void) fputc( (char) cur_char , outfile);
}
}
}
fprintf(outfile,"\003\002\033%c%c\030\r\n",'%','9'); /* Turned off graphics mode: set line spacing 24/144" = 1/6"*/
#ifdef PC
fprintf(stderr,"Print using: COPY /B\n");
#endif
}
#endif /* OKIDATA */